<template>
    <div class="role-lists">
        <el-card class="!border-none" shadow="never">
            <div>
                <el-button v-perms="['notice.notice/add']" type="primary" @click="handleAdd">
                    <router-link :to="{
                        path: getRoutePath('notice.notice/add')
                    }">
                        <template #icon>
                            <icon name="el-icon-Plus" />
                        </template>
                        新增
                    </router-link>

                </el-button>
            </div>
            <div class="mt-4" v-loading="pager.loading">
                <div>
                    <el-table :data="pager.lists" size="large">
                        <el-table-column prop="id" label="ID" min-width="100" />
                        <el-table-column prop="name" label="名称" min-width="260" />
                        <!-- <el-table-column prop="desc" label="备注" min-width="150" show-overflow-tooltip />
                        <el-table-column prop="sort" label="排序" min-width="100" />
                        <el-table-column prop="num" label="管理员人数" min-width="100" /> -->
                        <el-table-column prop="update_time" label="创建时间" min-width="260" />
                        <el-table-column label="操作" width="290" fixed="right">
                            <template #default="{ row }">
                                <!-- <el-button link type="primary" v-perms="['/notice.notice/detail']" @click="handleEdit(row)">
                                    编辑
                                </el-button> -->
                                <el-button v-perms="['notice.notice/edit']" type="primary" link>
                                    <router-link :to="{
                                        path: getRoutePath('notice.notice/edit'),
                                        query: { id: row.id }
                                    }">
                                        编辑
                                    </router-link>
                                </el-button>
                                <el-button link type="primary" v-perms="['notice.notice/detail']" @click="handleAuth(row)">
                                    <router-link :to="{
                                        path: getRoutePath('notice.notice/detail'),
                                        query: { id: row.id }
                                    }">
                                        查看
                                    </router-link>

                                </el-button>
                                <el-button v-perms="['notice.notice/delete']" link type="danger"
                                    @click="handleDelete(row.id)">
                                    删除
                                </el-button>
                            </template>
                        </el-table-column>
                    </el-table>
                </div>
                <div class="flex justify-end mt-4">
                    <pagination v-model="pager" @change="getLists" />
                </div>
            </div>
        </el-card>
        <!-- <edit-popup v-if="showEdit" ref="editRef" @success="getLists" @close="showEdit = false" />
        <auth-popup v-if="showAuth" ref="authRef" @success="getLists" @close="showAuth = false" /> -->
    </div>
</template>

<script lang="ts" setup name="role">
import { noticeLists, noticeDelete } from '@/api/notice/notice'
import { usePaging } from '@/hooks/usePaging'
import feedback from '@/utils/feedback'
import { getRoutePath } from '@/router'
import {
    onMounted,
    onBeforeUpdate,
    ref,
    reactive,
    onBeforeUnmount,
    getCurrentInstance
} from "vue"


// import AuthPopup from './auth.vue'
// import EditPopup from './edit.vue'

// const editRef = shallowRef<InstanceType<typeof EditPopup>>()
// const authRef = shallowRef<InstanceType<typeof AuthPopup>>()
const showEdit = ref(false)
const showAuth = ref(false)
const { pager, getLists } = usePaging({
    fetchFun: noticeLists
})
const handleAdd = async () => {
    showEdit.value = true
    await nextTick()
    // editRef.value?.open('add')
}

const handleEdit = async (data: any) => {
    showEdit.value = true
    await nextTick()
    // editRef.value?.open('edit')
    // editRef.value?.setFormData(data)
}

const handleAuth = async (data: any) => {
    showAuth.value = true
    await nextTick()
    // authRef.value?.open()
    // authRef.value?.setFormData(data)
}

// 删除角色
const handleDelete = async (id: number) => {
    await feedback.confirm('确定要删除？')
    await noticeDelete({ id })
    getLists()
}


onMounted(() => {
    getLists()
})
</script>
